// 导入 express 模块
const express = require('express')
// 创建 express 的服务器实例
const app = express()

const joi = require('@hapi/joi')
//导入配置文件
const config = require('./config')
//导入解析token的中间件
const expressJWT = require('express-jwt')

//配置cors解决跨域
const cors = require('cors')
app.use(cors())

//配置解析表单数据的中间件
//解析 application/x-www-form-urlencoded 格式的表单数据
app.use(express.urlencoded({extended:false}))

//托管静态资源
app.use('/uploads',express.static('./uploads'))

//声明一个全局中间件，为 res 对象挂载一个 res.cc() 函数
app.use(function (req,res,next) {
    // status = 0 为成功； status = 1 为失败； 默认将 status 的值设置为 1，方便处理失败的情况
    res.cc = function (err,status = 1) {
        res.send({
            //状态
            status,
            //判断err是错误对象还是字符串
            message: err instanceof Error ? err.message : err
        })
    }
    //将程序转交给路由模块
    next()
})

//在注册路由之前，配置解析 Token 的中间件
// 使用 .unless({ path: [/^\/api\//] }) 指定哪些接口不需要进行 Token 的身份认证
app.use(expressJWT({ secret: config.jwtSecretKey }).unless({ path: [/^\/api\//] }))

//导入并使用用户注册登录路由模块
const userRouter = require('./router/user')
app.use('/api',userRouter)
//导入并使用用户信息路由模块
const userinfoRouter = require('./router/userinfo')
// 注意：以 /my 开头的接口，都是有权限的接口，需要进行 Token 身份认证
app.use('/my',userinfoRouter)
//导入并使用文章分类路由模块
const artCateRouter = require('./router/artcate')
//为文章分类的路由挂载统一的访问前缀 /my/article
app.use('/my/article',artCateRouter)
//导入并使用新建发布文章路由模块
const articleRouter = require('./router/article')
//为发布文章的路由挂载统一的访问前缀 /my/article
app.use('/my/article',articleRouter)


//在路由模块之后定义全局错误级别中间件
// 错误中间件
app.use(function (err, req, res, next) {
    // 捕获数据验证失败
    if (err instanceof joi.ValidationError) return res.cc(err)
    //捕获身份认证失败的错误
    if (err.name === 'UnauthorizedError') return res.cc('身份认证失败！')
    // 未知错误
    res.cc(err)
  })

// 调用 app.listen 方法，指定端口号并启动web服务器
app.listen(3000, function () {
  console.log('api server running at http://127.0.0.1:3000')
})
